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(57) Abstract 



A personnel and asset tracking system for locating and tracking personnel and assets throughout an awareness area (2). The system 
includes a central server (10), a communication network to which the central server (10) is connected, a tag (50, 52) associated with each 
person (51) and asset (55) to be tracked, and at least one monitoring system (25) to locate and track tags (50, 52) within a sub-area (4) 
of the awareness area (2). The tags (50, 52) include a transmitter for periodically transmitting a unique identifier for. each person (51) 
and asset (55). The monitoring system includes a router (14) connected to the communication network, at least one intermediate location 
processor (16) that transmits location messages to the router (14), and at least one receiver node (18) connected to each intermediate location 
processor (16), such that when the receiver node receives a transmission from the tag (50, 52), the receiver node (18) creates and sends a 
location message to the intermediate location processor (16), the intermediate location processor (16) transmits the location message to the 
router (14), and the router (14) transmits the location message to the central server (10) over the network. 
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PERSONNEL AND ASSET TRACKING METHOD AND APPARATUS 

TECHNICAL FIELD OF THE INVENTION 
This invention relates to a system for tracking personnel and assets over an extended 
area composed of one or more sub-areas which are monitored by sub-area monitoring 
5 systems. The sub-area monitoring systems communicate with and update location databases 
resident on a common central server. Clients communicate with and access the databases of 
the central server via an Internet web browser interface. 

BACKGROUND OF THE INVENTION 
Location and tracking systems using object tags, a plurality of receivers located at 
10 known locations and a central computer are well known in the art. The tags periodically 
transmit a unique ID signal which is received by the receivers and the central processor 
combines the receiver location with the tag ID to determine the location of the object 
associated with the tag. However, these systems have several limitations. 
Location data maintained by the central processor has limited accessibility from locations 
15 other than the central processor. All location data is maintained by the central processor. 
Any location monitoring devices that send location data to the central processor must be 
specifically designed to work with the central processor, and must be like all the other 
location monitoring devices connected to the central processor. All of the location data must 
be sent to the central processor and anytime communication with the central processor is lost 
20 the location data collected by the disconnected location monitoring devices is inaccessible. 
The central processor receives location updates but does not forward location data to other 
monitoring systems. 

SUMMARY OF THE INVENTION 
Thus, it is an object of the present invention to create a central location database that 
25 can be accessed from any computer with network access to the central server through Intranet 
or Internet using a standard web browser interface. The web browser interface is created 
using a Microsoft technology called Active Server Pages and the programming language 
VBScript. Active Server Pages allows the creation of dynamic web pages which are tailored 
according to the requests of the client queries. The dynamic server pages are interpreted by 
30 the web browser to provide virtually complete access to the location databases and other 
databases maintained on the central server. Any computer with communications network 
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access to the central server and supporting a web browser interface can access the location 
data and other data stored on the central server. 

It is an object of the present invention to allow the tracking and locating of objects 
over a large area by combining the object transmissions received over multiple sub-areas 
which are monitored by autonomous monitoring systems interconnected through a 
communications network. Each location monitoring system sends the location updates to the 
central server over the communications network. The central server can maintain location 
data for a large area by receiving location updates over several sub-areas which each have a 
location monitoring, system tracking object tags in their particular sub-area. The area and 
sub-areas could be a building and its floors, a campus and its buildings, or several campuses 
and the floors of each of the buildings on each of the campuses. The sub-area monitoring 
systems only have to be able to track the same tags and have access to the central server over 
a communications network for a client connected to the central server to obtain location 
information on an object anywhere in the awareness area. 

It is an object of the present invention to support locating and tracking over the entire 
area using both dependent locating and tracking system, locating and tracking systems which 
depend upon the central database to store location data and to respond to database queries, 
and independent locating and tracking systems, locating and tracking systems which forward 
location data to the central server as well as maintaining local sub-area location databases. 
Each of the sub-area monitoring systems can either send all data to the central server for 
recording, a dependent monitoring system, or have a local database for objects assigned to the 
local sub-area and also send location updates to the central server, an independent monitoring 
system. If either monitoring system loses communication with the central server it will store 
location updates to transmit when communication is restored. An independent monitoring 
system will continue to support local location queries for the objects assigned to its sub-area 
when communication is lost with the central server. The central server can also pass location 
updates and messages back to the independent monitoring systems. If an object assigned to 
sub-area A is in another sub-area monitored by the central server then location updates can be 
recorded at the central server and forwarded to sub-area A to keep the local database updated 
even when the objects are outside sub-area A. The independent monitoring system can also 
assign new tags to the sub-area and receive updates from anywhere monitored by the central 
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server. However, when communication with the central server is lost only objects within the 
sub-area can be tracked. 

Additional objects, advantages and novel features of the invention are set forth in the 
description that follows, and will become apparent to those skilled in the art upon reviewing 
5 the drawings in connection with the following description. 

DESCRIPTION OF THE DRAWINGS 
Fig. 1 is a block diagram of the layout of the personnel and asset tracking system. 
Fig. 2 shows the interconnection of the components of a dependent monitoring 

system. 

10 Fig. 3 shows the interconnection of the components of a receiver node. 

Fig. 4 is a detailed design of the receiver node audio annunciator. 
Fig. 5 is a detailed design of the receiver node auxiliary I/O connector. 
Fig. 6 shows the procedure used by a location processor for processing a presence 
message. 

15 Fig. 7 shows the procedure used by a location processor for processing an entry 

message. 

Fig. 8 shows the procedure used by a location processor for processing an exit 
message. 

Fig. 9 shows the procedure used by a location processor for processing a presence 
20 message when the location processor has exit timer capability. 

Fig. 10 shows the procedure used by a location processor when an exit timer expires. 

Fig. 1 1 shows the procedure used by a location processor for processing an exit 
message or the expiration of an exit timer when the location processor has an extended exit 
timer. 

25 Fig. 12 shows a block diagram of the central server web browser interface and the 

associated application programs and databases on the central server with connection to 
clients. 

Fig. 13 is a flowchart of the rules processing by the Awareness Engine Monitor when 
a location update message is received. 

30 
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DESCRIPTION OF THE PREFERRED EMBODIMENT 
Fig. 1 illustrates the interconnection of the primary components of the personnel and 
asset tracking system. The heart of the system is the central server 10 which maintains the 
awareness area databases 11 for the system over the entire area in which awareness of 
personnel and assets is to be monitored, the awareness area 2. The central server 10 receives 
location and status updates from at least one monitoring system through a communications 
network 12. Each monitoring system monitors personnel and assets throughout a sub-area of 
the awareness area, a sub-awareness area. Fig. 1 shows an independent monitoring system 25 
monitoring a sub-awareness area 4 and a dependent monitoring system 15 monitoring another 
sub-awareness area 6. Both the dependent monitoring system 15 and the independent 
monitoring system 25 send location updates to the central server 10 over the network 12. The 
dependent monitoring system 15 does not maintain a local database, and thus depends on the 
central server 10 to handle location queries from clients 40. The independent monitoring 
system 25 maintains a local sub-awareness area 4 location database on the master station 24, 
and thus can support local queries for objects assigned to it independent of the central server 
10. The independent monitoring system 25 receives signals transmitted by a personnel badge 
50 worn by a person 51 and an asset tag 52 attached to an asset 55. The dependent 
monitoring system 15 receives signals transmitted by another personnel badge 50 worn by a 
person 53 and another asset tag 52 attached to an asset 57. An awareness area 2 and sub- 
awareness areas 4, 6 could be a building and its floors or a campus and its buildings. Each 
entity to be monitored in the awareness area 2 wears a personnel badge 50 or an asset tag 52 
which transmits a unique object ID signal. 

Access to the awareness area databases 11 maintained at the central server 10 can be 
gained from a client 40 or an administrative station 44 through the network 12. Client 40 can 
be connected to the network 12 locally (e.g. Intranet) or remotely (e.g. Internet). Independent 
monitoring system 25 can also access the awareness area databases 1 1 maintained on the 
central server 10 through the hospital network 12. 

There are two types of sub-awareness area monitoring systems. A dependent 
monitoring system 15 is connected to the hospital network 12 through a router 14 as shown in 
Fig. 2. A dependent monitoring system 15 does not maintain sub-awareness area databases or 
support sub-awareness area queries but rather forwards all information to the central server 
10. A dependent monitoring system 15 is comprised of a router 14, at least one hub 16 and a 
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plurality of nodes 18. Each node 18 continuously monitors a particular area in the sub- 
awareness area for personnel badge 50 and asset tag 52 transmissions. Each node 18 
communicates with and sends location messages to a hub 16. The hub 16 communicates with 
and sends location messages to the router 14. The router 14 communicates with and sends 
5 location messages to the central server 10 over the hospital network 12. 

The second type of sub-awareness area monitoring system is an independent 
monitoring system 25 as disclosed in U.S. Patent 5,561,412 which is hereby incorporated by 
reference. An independent monitoring system 25 has a set of personnel badges 50 assigned 
for which it maintains a local database on its master station 24 which also supports local 

10 queries and status messages. The master station 24 communicates with the central server 10 
over the hospital network 12. 

In either type of monitoring system the process is triggered by the reception of a 
personnel badge 50 or asset tag 52 transmission at a receiver node 18. The receiver node 18 
generates a presence or entry message which is sent to a downstream location processor. A 

15 detailed diagram of the receiver node 18 is shown in Fig. 3. The receiver 18 includes a 

microprocessor 30. The receiver 18 of a dependent monitoring system 15 receives power and 
data inputs 34 from the hub 16. The dip switches 36 are used to configure the receiver 18 for 
use with either a dependent monitoring system 15 or an independent monitoring system 25. 
The multiple infrared detectors 32 receive the transmissions of personnel badges 50 and asset 

20 tags 52 and relay them to the microprocessor 30, which processes the badge transmissions 
and can forward a location message to the next upstream location processor over the data 
lines 34. The 48 bit silicon ID is set to a unique address to identify the node 18. The node 18 
also has a LED 60, an audio annunciator 62 and a auxiliary I/O connector 64. 

A detailed drawing of the audio annunciator 62 is shown in Fig. 4. If the audio 

25 annunciator 62 of the node 18 is selected then a control signal will be sent by the 

microprocessor 30 at the connection 412 through the resistor 414. A resistor 416 ties the base 
of the transistor 418 to the voltage source. The control signal from the transistor 418 passes 
through resistors 422 and 424 to activate the audio switches 424, 430 and the audio line 
transformer 400. The audio signal is input from an audio amplifier over connector 408. The 

30 audio input is processed simultaneously by two parallel and totally isolated audio switches. 
The audio signal passes across a pair of optically isolated FET switches 424, 430 which 
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transmit an optical signal to the photo-transistors 426, 432 which are each inparrallel with a 
noise suppression diode 428, 434. The output audio signal is input to the audio line 
transformer 400 through connector 402. The output of the audio line transformer 400 is sent 
through connectors 402 and 406 to speaker 410. Switch 404 controls the volume of the signal 
5 sent to speaker 406. 

A detailed diagram of the auxiliary I/O connector 64 of the node 18 is shown in Fig. 5. 
The auxiliary I/O connector 64 is connected to the microprocessor 30 through the lines 500- 
512. Each line to the microprocessor 30 is protected by a current limiting resistor 517-529 
and a zener diode clamp 540-553 to protect from reverse or over- voltages. Each line is also 

10 connected to a input/output line at connector 560. These auxilary lines could be used for 

inputs or outputs. Examples of inputs are monitoring room temperatures or the presence of 
persons without a personnel badge or for outputs. Examples of outputs are thermostat 
controls, light controls or buzzers. 
Inter-Location Messages 

15 Both a dependent monitoring system 15 and an independent monitoring system 25 is 

comprised of an infrastructure with multiple location processor levels. The most upstream 
location processors are the nodes 18 which receive the badge/tag transmissions and pass them 
downstream and generate the initial location messages. These location messages are passed 
downstream to intermediate location processors which pass the location messages to the 

20 downstream location processors which are either a router 14 or a master station 24 that passes 
the location message to the central server 10. A location message begins with the reception 
of an object ID from a personnel badge 50 or asset tag 52 transmission and ultimately ends 
with the updating of a database 11 such that the best location data is available for all objects 
being tracked. A location processor can function in either a pass-through or a buffered mode. 

25 In pass-through mode any location message received by the location processor is passed to 
the next location processor in the stream leading to the central server 10. In buffered mode 
the location processor maintains a cache with a stack for each object ID it is currently 
tracking and only passes along changes in the status of a particular object ID. The inter- 
location messages in buffered mode can be either presence messages, entry messages or exit 

30 messages, while the inter-location messages in pass-through mode are presence messages. 

Each of these messages is for a particular personnel badge 50 or asset tag 52 object ID at a 
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particular awareness area location. Entry and exit messages also have a time stamp 
associated with them identifying the time the event occurred. 

A presence message simply indicates that a particular object ID is present at a 
particular awareness area location." A presence message is generated at a node 1 8 when it 
5 receives a personnel badge 50 or asset tag 52 transmission or is received at a downstream 
location processor from an upstream pass-through location processor. The processing of a 
presence message by the first buffered location processor is shown in Fig. 6. The process is 
initiated by the reception of a tag transmission at a node 18 or the reception of a presence 
message from an upstream location processor 110. The location processor receiving the 
10 presence message checks if it is currently tracking this object ID 1 1 1 . If the object ID is 
currently being tracked, the location processor checks if the top entry in the stack for this 
object ID already shows the same location as the presence message 112. If the top entry of 
the stack already contains this object ID and receiver pair then there is no change in the 
object's location and no further processing is required. If its cache does not contain this 
15 object ID or it shows a different location then there has been, a location change for this object. 
The location processor adds the object ID and receiver pair to the top of the stack for the 
object ID in its cache 114, time stamps the message 1 16, and sends an entry message to the 
next downstream location processor 118. 

An entry message indicates the transition of an object ID from not being detected at a 
20 particular, location to being detected at that particular location. An entry message is created 
by an upstream location processor and sent downstream. The processing of an entry message 
is shown in Fig. 7. This process is initiated by the receipt of an entry message 120. The 
location processor receiving the entry message checks if it is currently tracking this object ID 
121. If the object ID is currently being tracked, the location processor checks if the top entry 
25 in the stack for this object ID already shows the same location as the entry message 122. If 
the top entry of the stack already contains this object ID and receiver pair then there is no 
change in the object's location and no further processing is required. If its cache does not 
contain this object ID or it shows a different location then there has been a location change 
for this object. The location processor adds the object ID and receiver pair to the top of the 
30 stack for the object ID in its cache 124, time stamps the message 126, and sends an entry 
message to the next downstream location processor 128. 
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An exit message indicates the transition of an object ID from being detected at a 
particular location to not being detected at that particular location. An exit message is created 
by an upstream location processor and sent downstream. The processing of an exit message 
is shown in Fig. 8. This process is initiated by the receipt of an exit message 130. The 
location processor receiving the exit message checks if it is currently tracking this object ID 
131. If the object ID is currently being tracked, the location processor checks if the top entry 
in the stack for this object ID already shows the same location as the presence message 1 12. 
If top entry does not contain this object ID and receiver pair then the object ID is not 
associated with the location and no further processing is required. If the top entry of the stack 
contains this object ID and receiver pair then the object ID and receiver pair is removed from 
the cache 134 and the exit message is sent to the next downstream location processor 136. 
Buffered location processors can maintain up to two timers related to exit processing. The 
first, an exit timer is kept at the most upstream buffered location processor which could be a 
node 18 receiving object ID transmissions from a personnel badge 50 or asset tag 52, or a 
downstream location processor receiving presence messages from an upstream pass-through 
location processor. The exit timer is used to generate an exit message if presence messages 
are not received for a particular object over a predetermined time interval. 

The initialization of an exit timer for a particular object ID is shown in Fig. 9. The 
process is initiated by the receipt of a presence message 140. The location processor 
receiving the presence message checks if its cache already contains this object ID and 
receiver pair 142. If its cache already contains this object ID and receiver pair then the exit 
timer is reset 149 and no further processing is required. If the cache does not contain this 
object ID and receiver pair then an entry condition has taken place for this object. The 
location processor adds the object ID and receiver pair to its cache 144, sets the exit timer for 
this object depending on whether it is an personnel badge 50 or asset tag 52 transmission 146, 
time stamps the object ID and receiver pair 147, and sends an entry message to the next 
downstream location processor 148. 

The process that occurs when the exit timer expires for a particular object ID and 
location pair is shown in Fig. 10. This process is initiated by the expiration of the exit timer 
150 which indicates that no presence messages have been received by the location processor 
since the exit timer was last set, and therefore the object is assumed to have left the location it 
was last associated with by this location processor. When the exit timer expires the object ID 
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and receiver pair is removed from the cache 152. The location processor then checks if the 
object ID/location pair associated with this exit timer is at the top of its cache 154. If this pair 
is at the top of the stack an exit message is sent downstream 156. The location processor then 
-checks if there are remaining entries in the stack for this object ID 158. If there are remaining 
entries, an entry message is sent downstream for the new location at the top of the cache for 
this object ID 159. 

The second timer associated with exit message processing is an extended exit timer. 
An extended exit timer further delays the sending of an exit message downstream as shown in 
Fig. 11. Extended exit timer processing is initiated by the receipt of an exit message 160 or 
the expiration of an exit timer 162, either of which starts the extended exit timer 164 if the 
location processor is equipped for this processing. The location processor will then check for 
the expiration of the extended exit timer 166. If the extended exit timer expires before the 
receipt of an entry message for the particular object ID then an exit message is sent 
downstream with the time stamp of the original exit message 174 and no further processing is 
required. If an entry message is received for the particular object ID before the extended exit 
timer expires 168 then the location processor checks if the location of the entry message is the 
same as the object ID/location pair associated with the extended exit timer 170, If the 
location is the same then the object has not changed location and the extended exit timer is 
canceled 172 and no further processing is required. If the location is different then the object 
has changed location; the extended exit timer is canceled 176, an exit message is sent for the 
location associated with the extended exit timer with the time stamp of the entry message 
178, and an entry message is sent for the new location with the time stamp of the entry 
message 179. 

A downstream location processor can request an upstream location processor to send 
the contents of its cache showing the object IDs that the upstream location processor is 
tracking. The response message consists of a list of object IDs and their associated locations. 
Action Message Processing 

Each personnel badge 50 is equipped with an action button or switch which is used to 
send an alert signal. A unique system response can be defined for the reception of an alert 
signal from each personnel badge 50 tracked by the system. The primary response is 
maintained at the central server 10, and for an independent monitoring system 25 a secondary 
response can be maintained at the master station 24. The secondary response is initiated if 
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either communication is lost between the central server 10 and the master station 24 or if no 
primary response has been programmed at the central server 10. 

The object IDs of all personnel badges 50 and asset tags 52 have a zero for the most 
significant bit. When the action button or switch is triggered then the most significant bit is 
set to "1" which constitutes an alert signal. When a location processor receives an alert signal 
it makes an audible or visual response if equipped with a means for audible or visual 
response. 

A sub-awareness area monitoring system passes the alert signal to the central server 
10. The central server 10 records the time that the alert signal was sent and looks up the 
programmed response for the particular object ID. The programmed response can include 
instructions to send a notification message to one or more monitoring clients 40, or to direct 
an audio message to the audio annunciator of one or more nodes 18, or to send a message to a 
pocket pager. The central server 10 sends notification messages to all monitoring clients 40, 
nodes 18 and pocket pagers as instructed by the pre-programmed response. Each monitoring 
client 40 that receives the notification message, sounds an audible tone indicating that a 
notification message has been received and a pop-up window is displayed on the monitoring 
client 40 indicating the personnel badge 50 that has sent the alert signal and the location from 
where the alert signal was sent. The person at the monitoring client 40 acknowledges the 
alert signal by closing the pop-up window, which sends an alert acknowledgment message 
back to the central server 10 which records the alert acknowledgment time. An independent 
monitoring system 25 may also have a secondary response stored on the master station which 
is initiated in addition to the central station 10 response. When the secondary alert process 
has been acknowledged the master station 24 sends an alert acknowledgment message back to 
the central server 10 which records the alert acknowledgment time. 
Central Server and Client Communication 

A top-level diagram of the communications between the central server 10 and 
potential clients 14, 24, 34 over the network 12 is shown in Fig. 12. There are three types of 
clients that are in contact with the central server 10. The first is a dependent monitoring 
system router 14. The router 14 is in communication with the central server 10 sending 
location messages for the sub-awareness area that the dependent monitoring system 15 is 
monitoring. The second type of client is an independent monitoring system master station 24. 
The master station 24 is in two-way communication with the central server 10 sending 
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location messages for the sub-awareness area that the independent monitoring system 25 is 
monitoring, and primarily receiving location updates for personnel badges 50 assigned to the 
independent monitoring system 25 which are received from outside the sub-awareness area 
that the independent monitoring system 25 is monitoring. The third type of client is a 
5 network client 40. Network clients 40 primarily query the central server 10 for location and 
tracking data to create screen displays or reports, they do not provide location updates but 
they can update other data on the central server 10. 

The interface between the central server 10 and the network client 40 is a Web 
browser interface commonly used on the Internet. The interface between the central server 10 

10 and the dependent monitoring system router 14 or the independent monitoring system master 
station 24 can be web browser based or through other network communication methods. The 
web server 210 is developed with Internet Information Server (IIS) software, developed by 
Microsoft, on the central server 10 provides the necessary functionality to host a Web site that 
can intercept and interpret information requests or updates, call the service providers to make 

15 the necessary database queries or updates, and create a a dynamic Web page responsive to the 
information request or update. The web server 210 can service multiple clients over an 
Internet or Intranet from a single central server 10. The service providers for the web server 
210 are applications that can update, query and maintain databases containing information of 
interest to the clients. 

20 The primary location and tracking databases on the central server 10 are as follows. 

The Location Update Cache 290 contains the current location of all personnel badges 50 and 
asset tags 52, ordered by location. The Location/Tag ID Cache 292 contains the current 
location of all personnel badges 50 and asset tags 52, ordered by Tag ID. Having the current 
location of all personnel badges 50 and asset tags 52 ordered by both location and Tag ID 

25 allows increased system performance when responding to database queries. The Rules Cache 
296 contains rules defined for objects and locations such that when a rule isviolated a 
message is sent to interested client 24, 34. The Registered Interests Cache 294 contains a 
cross-reference between clients 24, 34 and interests for which the client 24, 34 is registered. 
The Database Transaction Queue 298 contains all of the incoming and processed transactions 

30 from networked clients. The SQL Database 300 contains a record of all database change 
events that have occurred and their times. 
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The Location Update application 212 receives location updates from dependent 
monitoring systems 15 and independent monitoring systems 25. The location updates can be 
in the form of entry messages or exit messages if the monitoring system is buffered or in the 
form of presence messages if the monitoring system is pass-through. The Location Update 
application 212 updates the object ID/location pair in both the Location Update Cache 290 
and the Location/Tag ID Cache 292, and also enqueues the transaction in the Transaction 
Queue 298. 

The Interests application 214 receives interests from clients that a user would like to 
add to or delete from the Registered Interests Cache 294. Interests are events that a client 
application wants to be notified of when the event occurs. Examples of interests are alarm 
events and personnel badge 50 assignment changes. The Interests application 214 records the 
event and client that wants to be notified of the event in the Interests Cache 294 and also 
enqueues the transaction in the Transaction Queue 298. 

The Tag Association application 218 manages the association and disassociation of 
personnel badges 50 and asset tags 52 to people and assets, respectively. The Tag 
Association application 218 receives instructions from a client and makes the appropriate 
updates to the Location/Tag DD Cache 292 and enqueues the transaction to the Transaction 
Queue 298. 

The Non-Interactive Database application 220 handles all database transactions that 
do not require a user response. The Direct Database Access application 222 handles all 
transactions that require access to the SQL Database 300. 

The Awareness Engine Monitor 230 constantly watches the caches for the occurrence 
of alarm and interest events stored in the Interests Cache 294 or violations of the rules stored 
in the Rules Cache 296. When an interest event occurs or a rule has been violated the 
Awareness Engine Monitor 230 sends an appropriate notification to the clients that have 
registered for that event. A flowchart of the rules processing performed by the Awareness 
Engine Monitor 230 is shown in Fig. 13. The process is initiated by the receipt of a location 
message by the web server 210 of the central server 10, as shown in step 310. When the 
location update is passed to the Awareness Engine Monitor 230, the following processes are 
performed. First, the location entry is updated in the Location/Tag ID Cache 292 to indicate a 
new object ID at this location, as shown in step 320. The Awareness Engine Monitor 230 



WO 99/23623 PCT7US98/22908 

13 

then checks if any rules concern this location 322. Second, the object ID entry in the 
Location Update Cache 290 is updated to indicate that the object ID is located at the new 
location, as shown in step 330. The Awareness Engine Monitor 230 then checks if any rules 
concern this object ID 332. Third, the Awareness Engine Monitor 230 checks if there are any 
5 global rules, those that do not concern a particular object or location ID, triggered by this 

update 340. The Awareness Engine Monitor 230 then checks whether any of the rules found 
in steps 322, 332 and 340 are violated, as shown in step 350. If any rule was violated the 
Awareness Engine Monitor 230 checks if the Registered Interests Cache 294 has a client to be 
notified of the rule violation 352. A message is sent by the central server to any registered 

10 client indicating the rule violation that occurred 354. The client can then perform the 
response it is programmed to perform when the notification is received 356. 

The Subscription Service application 216 is also used for event notification and 
alarms. The Subscription Service application 216 sends the notification message to the client 
that has subscribed to be notified of a particular event. An example is an independent 

15 monitoring systems 25 that wants to be informed when a personnel badge 50 assigned to the 
sub-awareness area being monitored by the independent monitoring system 25 is detected 
outside of that particular sub-awareness area. In this instance, the Subscription Service 
application 216 will be initiated when an assigned badge 50 of the independent monitoring 
system 25 is detected outside its sub-awareness area and the Subscription Service application 

20 216 will send a location message to the independent monitoring system 25 to be used to 
update the local sub-awareness area database being maintained by the master station 24. 
The Awareness Engine Queue Processor 224 processes all transactions in the enqueue of the 
Transaction Queue 298 to update the SQL Database 300. When a request is received by the 
Web Server 210 it is handed off to the appropriate service provider application. If the request 

25 involves a database update, the appropriate update information is placed in Transaction 

Queue 298. Once a transaction is successfully processed by the Awareness Engine Queue 
Processor 224 it is moved to the dequeue of the Transaction Queue 298. If a transaction is 
not successfully processed by the Awareness Engine Queue Processor 224 it is moved to a 
separate part of the dequeue for failed transactions. From here an Administrative Client 44 

30 can review the transaction, make any necessary changes and requeue the transaction for 

processing by the Awareness Engine Queue Processor 224. An Administrative Client 44 also 
periodically cleans up dequeued transactions. 
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The data flow from the tag transmission to the appropriate database updates at the 
central server 10 is as follows. A personnel badge 50 or asset tag 52 transmission is detected 
by a receiver node 18 and the receiver node 18 generates a location message which it sends 
downstream. If the receiver node 18 is part of a dependent monitoring system 15 the location 
message is sent to the router 14 which sends the location message across the network 12 to 
the central server 10 without any intermediate storage. If the receiver is part of an 
independent monitoring system 25 it is stored at the master station 24 and the master station 
24 also sends the location message across the network 12 to the central server 10. The web 
browser 210 on the central server 10 receives the location message. The web browser 210 
passes the location message to the Location Update program which updates the Location 
Update cache 290 and the Location/Tag ID Cache 294 and checks the Rules Cache 296 for 
any actions that are to be performed based upon the update. A transaction is also sent to the 
Transaction Queue 298 which will be processed by the Transaction Queue Processor 224 to 
make a historical record of the update on the SQL Database 300. 
Client Interfaces 

The master station 24 of an independent monitoring system 25 can be a client of the 
central server 10. The nodes 18 of the independent monitoring system -25 receive 
transmissions from personnel badges 50 and asset tags 52 in the sub-awareness area covered 
by the independent monitoring system 25. These transmissions are converted into location 
messages which are forwarded to the master station 24 which updates the local sub-awareness 
area database and transmits the location update to the web browser 210 on the central server 
10 which collaborates with the appropriate programs to update the Location Update cache 
290, the Location/Tag ID Cache 292 and the SQL Database 300. 

The independent monitoring system 25 has several important advantages due to its 
connection to the central server 10. The first advantage is that the independent monitoring 
system 25 can track the personnel badges 50 and asset tags 52 assigned to the independent 
monitoring system 25 even when they are outside of the sub-awareness area monitored by the 
independent monitoring system 25, as long as they are within the awareness area. All of the 
objects that an independent monitoring system 25 wants assigned are listed in the Interests 
Database 294 with the identity of the independent monitoring system to be notified. When an 
object is within the awareness area but outside the independent monitoring system's 25 sub- 
awareness area, the central server 10 will receive a location message for the object from 
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another client. When this location message is detected by the Awareness Engine Monitor 230 
it will recognize the interest in the Interest Database 294 and send a location message for the 
object to the independent monitoring system 25 using the Subscription Service application 
216. 

5 This same functionality can be used by an independent monitoring system 25 to add 

objects that it wants to track in its local sub-awareness area database. A message would be 
sent from the master station 24 of the independent monitoring system 25 to the Web Server 
210 of the central server 10 to register an interest for the new object. The Interests 
application 214 would record the interest in the Interests Database 294 and the Awareness 
1 10 Engine Monitor 230 would inform the independent monitoring system 25 of any location 
messages received for the associated object badge/tag outside the independent monitoring 
system's 25 sub-awareness area. 

The connection to the central server 10 also allows the independent monitoring system 
25 to resolve the identity of personnel badges 50 and asset tags 52 which are not assigned to 

15 the sub-awareness area when they are detected within the sub-awareness area. The master 

station 24 of the independent monitoring system 25 will send a location message for an object 
not assigned to its sub-awareness area and also store the location message in a visitor cache. 
If the master station 24 does not know the identity of the object associated with the location 
message it will send a query to the Internet Information Server 210 of the central server 10. 

20 The Direct Database Access program 222 in the central server 10 will query the SQL 

Database 300 and send a response containing the identity of the object for use in the local 
sub- awareness area database of the independent monitoring system 25. 

Connection to the central server 10 also allows a user at the master station 24 of the 
independent monitoring system 25 to perform location searches for any locateable entity in 

25 the awareness area known to the central server 10 or other functions that can be performed 
from a client 40. 

A client 40 is used to access information maintained by the central server 10. A client 
40 has a web browser interface through which a user communicates with the Web Server 210 
of the central server 10 to query or update information maintained in the central server 10 
30 databases. The two primary location viewing applications of the client 40 are the Personnel 
View and Asset View functions. The client 40 can be a computer assigned to an individual 
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that contains the Personnel View and Asset View software packages and has access to the 
central server 10 via an Internet or Intranet connection. 

Personnel View allows a user to locate personnel associated with personnel badges 
50, to assign and deassign personnel to personnel badges for tracking in the awareness area, 
to maintain and update personnel information stored by the central server 10, and to perform 
administrative functions. When a user wishes to use the Personnel View function they must 
first login to the system to indicate the user's identity and to prevent unauthorized access. 
A personnel search can be performed from a standard search screen or the user can set-up a 
list of common searches they wish to perform and simply select one of these pre-defined 
searches. Personnel searches can be run based on first name, last name, department, skill and 
location with filter options of begins with, contains, or equals. Fields maintained in the 
Personnel Database on the central server 10 include name, department, skill, time since badge 
last seen, location where badge last seen, nearest phone number to location where badge last 
seen, name and phone number of person taking calls for this person, and mobile phone 
number for person. When the information is displayed for the located person or persons 
several fields may be highlighted showing a link to additional information about the 
hyperlinked item. For instance, location, department, organization or skill fields could be 
highlighted to indicate that an explanation of the contents or codes used for each of these 
fields is available which the user can access by selecting the highlighted field. An edit option 
is also available to the user to edit any information stored in the personnel databases on the 
central server 10 for the user login entered or for those personnel that have authorized updates 
by the user login entered. 

A user can also log onto Personnel View and enter status information. An out to 
lunch or gone home option will set the location of the badge associated with the logged on 
user to "Out to Lunch" or "Gone Home" respectively and provide an expected return time. 
The expected return time can be either a default time or default length of time from when the 
message was activated or can be over-ridden by a time entered by the user. A search that 
includes that user will return the location message and expected return time until the expected 
return time is passed. After the expected return time passes the normal location message will 
be returned for the user. A do not disturb option, if selected by the user, will display "Do Not 
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Disturb" along with the location information for any search performed that returns the user's 
location. This message will continue to be displayed until disabled by the user. 
Asset View allows a user to locate assets associated with an asset tag 52, to assign and 
deassign assets to asset tags for tracking in the awareness area. When a user wishes to use the 
5 Asset View function they must first login to the system to indicate the user's identity and to 
prevent unauthorized access. 

An asset search can be performed from a standard search screen or the user can set-up 
a list of common asset searches they wish to perform and simply select one of these pre- 
defined searches. Asset searches can be run based on standard asset description, add-on 

10 description, asset ED, asset category, location, or vendor with filter options of begins with, 

contains, or equals. Fields maintained in the Asset Database on the central server 10 include 
asset name, asset serial number, time since tag last seen, location where tag last seen, asset 
owner's name and phone number. When the information is displayed for the located asset 
several fields may be highlighted showing a link to additional information about the 

15 hyperlinked item. 

A client 40 can also be equipped to support report generation and report design. The 
report design function is internal to the client 40 and allows the user to customize the content 
of a report and the arrangement of data fields. The report generator allows the user to select a 
predefined report which was designed with the report designer. When the user runs the report 

20 the report generator uses a web browser interface to communicate over a network connection 
to the web browser 210 of the central server 10. The necessary data from the central server 
databases is retrieved and sent back to the client 40. The report client formats the returned 
data according to the report design. The user can then display, print or save the report. 

It will be understood that various modifications can be made to the system disclosed 

25 in this application without changing the scope of the invention as set forth in the Claims 
attached hereto. 
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CLAIMS 

What is claimed is: 

1. A personnel and asset tracking system for locating and tracking personnel and 
assets throughout an awareness area, said system comprising: 

a central server, 

a communication network to which the central server is connected, 
a tag associated with each person and asset to be tracked including a 
transmitter for periodically transmitting a unique identifier for each person and asset; 

at least one monitoring system to locate and track tags within a sub-area of the 
awareness area including a master station/router connected to the communication network, at 
least one intermediate location processor that transmits location messages to the master 
station/router, and at least one receiver node connected to each intermediate location 
processor, such that when the receiver node receives a transmission from the tag, the receiver 
node creates and sends a location message to the intermediate location processor, the 
intermediate location processor transmits the location message to the master station/router, 
and the master station/router transmits the location message to the central server over the 
network; 

the central server including means for maintaining at least one awareness 
database which is updated by the location message and means for receiving communications 
from any computer connectable to the communication network, wherein the central server can 
receive messages from the networked computer, translate the message to determine database 
queries and updates, process the database queries and updates ompose, create a response 
message which includes the results of the database queries and updates, and transmit the 
response message to the networked computer. 

2. The system of claim 1 wherein the awareness databases include an interest 
database in which a client registers an interest for which some client wants to receive a 
notification message when events of that interest type occur, such that the central server 
monitors updates for all events and when events of the registered type occur, the central 
server creates a notification message indicating the occurrence of the event, the location 
where the event occurred and transmits this notification message to all clients that are 
registered to receive a notification message for this type of event. 
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3. The system of claim 2 wherein each tag includes an action button, and the 
awareness databases include a user-definable system response for each tag that is to be taken 
when the action button of the tag is triggered; such that upon triggering an action button on a 
tag the tag sends an alert location message, the alert location message is given priority and 
transmitted to the central server, the central server queries the awareness databases for the 
user-defined system response for the particular tag that originated the alert location message, 
the central server creates an alert notification message according and transmits the alert 
notification message according to the user-defined system response. 

4. The system of claim 3 wherein the intermediate location processors of the 
monitoring system include audio speakers such that when either one of a registered interest 
event and an action button activation event is detected, the intermediate location processor 
closest to either one of the location to be notified and the tag to be notified receives an audio 
message and transmits the audio message through the audio speaker indicating the 
notification event. 

5. The system of claim 3 wherein the intermediate location processors of the 
monitoring system include a microphone and an audio speaker such that when either one of a 
registered interest event and an action button activation event is detected, the intermediate 
location processor closest to either one of the location to be notified and the tag to be notified 
is put into two-way audio communication with the intermediate location processor closest to 
the location of the tag that triggered the event. 

6. The system of claim 1 wherein at least one of the monitoring systems 
maintains a local location database for locating and tracking tags assigned to the sub-area 
monitored by the monitoring system. 

7. The system of claim 6 wherein the master station is attached to a cluster 
network and at least one client computer is connected to the cluster network such that the 
client computer can access the local location database for the sub-area. 

8. A method of locating and tracking personnel and assets throughout an 
awareness area with a personnel and asset tracking system including a central server, a 
communication network connected to the central server, a tag associated with each person 
and asset to be tracked, each tag including a transmitter for periodically transmitting a unique 
identifier for each person and asset, a master station/router connected to the communication 
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network, a processor that transmits location messages to the master station/router, and a 
receiver connected to the central processor, the method comprising the steps of receiving a 
transmission from the tag, creating and sending a location message to the processor, 
transmitting the location message to the master station/router, transmitting the location 
message to the central server, updating an awareness database on the central server by the 
location message, receiving communications from a computer connected to the 
communication network, translating the communications to determine necessary database 
queries and updates, processing the database queries and updates, creasting a response 
message which includes the results of the database queries and updates, and transmitting the 
response message to the networked computer. 
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